ochirish va tahrirlash uchun apilar qoshildi
This commit is contained in:
@@ -32,7 +32,7 @@ class PlaceCreateSerializer(serializers.Serializer):
|
|||||||
district_id = serializers.IntegerField()
|
district_id = serializers.IntegerField()
|
||||||
|
|
||||||
def validate_name(self, value):
|
def validate_name(self, value):
|
||||||
if not Place.objects.filter(name=value).exists():
|
if Place.objects.filter(name=value).exists():
|
||||||
raise serializers.ValidationError({"name": "Place bu name bilan mavjud"})
|
raise serializers.ValidationError({"name": "Place bu name bilan mavjud"})
|
||||||
return value
|
return value
|
||||||
|
|
||||||
@@ -54,3 +54,34 @@ class PlaceCreateSerializer(serializers.Serializer):
|
|||||||
user=self.context.get('user'),
|
user=self.context.get('user'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class PlaceUpdateSerializer(serializers.Serializer):
|
||||||
|
name = serializers.CharField(required=False)
|
||||||
|
latitude = serializers.FloatField(required=False)
|
||||||
|
longitude = serializers.FloatField(required=False)
|
||||||
|
extra_location = serializers.JSONField(required=False)
|
||||||
|
district_id = serializers.IntegerField(required=False)
|
||||||
|
|
||||||
|
def validate_name(self, value):
|
||||||
|
if not Place.objects.filter(name=value).exists():
|
||||||
|
raise serializers.ValidationError({"name": "Place bu name bilan mavjud"})
|
||||||
|
return value
|
||||||
|
|
||||||
|
def validate(self, data):
|
||||||
|
if data.get('district_id'):
|
||||||
|
district = District.objects.filter(id=data['district_id']).first()
|
||||||
|
if not district:
|
||||||
|
raise serializers.ValidationError({"district_id": "District not found"})
|
||||||
|
data['district'] = district
|
||||||
|
return data
|
||||||
|
|
||||||
|
def update(self, instance, validated_data):
|
||||||
|
with transaction.atomic():
|
||||||
|
instance.name = validated_data.get('name', instance.name)
|
||||||
|
instance.latitude = validated_data.get('latitude', instance.latitude)
|
||||||
|
instance.longitude = validated_data.get('longitude', instance.longitude)
|
||||||
|
instance.extra_location = validated_data.get('extra_location', instance.extra_location)
|
||||||
|
instance.district = validated_data.get('district', instance.district)
|
||||||
|
instance.save()
|
||||||
|
return instance
|
||||||
@@ -20,6 +20,7 @@ urlpatterns = [
|
|||||||
[
|
[
|
||||||
path('list/', dis_view.DistrictListApiView.as_view(), name='district-list-api'),
|
path('list/', dis_view.DistrictListApiView.as_view(), name='district-list-api'),
|
||||||
path('create/', dis_view.DistrictCreateApiView.as_view(), name='district-create-api'),
|
path('create/', dis_view.DistrictCreateApiView.as_view(), name='district-create-api'),
|
||||||
|
path('<int:id>/', dis_view.DistrictDeleteUpdateApiView.as_view(), name='district-update-delete-api'),
|
||||||
],
|
],
|
||||||
)),
|
)),
|
||||||
# place
|
# place
|
||||||
@@ -27,6 +28,7 @@ urlpatterns = [
|
|||||||
[
|
[
|
||||||
path('list/', pl_view.PlaceListApiView.as_view(), name='place-list-api'),
|
path('list/', pl_view.PlaceListApiView.as_view(), name='place-list-api'),
|
||||||
path('create/', pl_view.PlaceCreateApiView.as_view(), name='place-create-api'),
|
path('create/', pl_view.PlaceCreateApiView.as_view(), name='place-create-api'),
|
||||||
|
path('<int:id>/', pl_view.PlaceDeleteUpdateApiView.as_view(), name='place-update-delete-api'),
|
||||||
]
|
]
|
||||||
)),
|
)),
|
||||||
]
|
]
|
||||||
@@ -1,3 +1,6 @@
|
|||||||
|
# django
|
||||||
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
# rest framework
|
# rest framework
|
||||||
from rest_framework import generics, permissions
|
from rest_framework import generics, permissions
|
||||||
|
|
||||||
@@ -58,4 +61,52 @@ class DistrictCreateApiView(generics.CreateAPIView, ResponseMixin):
|
|||||||
)
|
)
|
||||||
return self.failure_response(data=serializer.errors, message='malumot qoshilmadi')
|
return self.failure_response(data=serializer.errors, message='malumot qoshilmadi')
|
||||||
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')
|
||||||
|
|
||||||
|
|
||||||
|
class DistrictDeleteUpdateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = district_serializers.DistrictSerializer
|
||||||
|
queryset = District.objects.all()
|
||||||
|
permission_classes = [permissions.IsAuthenticated]
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
responses={
|
||||||
|
200: base_serializers.SuccessResponseSerializer(),
|
||||||
|
400: base_serializers.BaseResponseSerializer(),
|
||||||
|
500: base_serializers.BaseResponseSerializer(),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
def patch(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(District, id=id, user=request.user)
|
||||||
|
serializer = self.serializer_class(data=request.data, instance=obj)
|
||||||
|
if serializer.is_valid():
|
||||||
|
name = serializer.validated_data.get('name')
|
||||||
|
obj.name = name
|
||||||
|
obj.save()
|
||||||
|
return self.success_response(
|
||||||
|
data=district_serializers.DistrictSerializer(obj).data,
|
||||||
|
message='Malumot tahrilandi'
|
||||||
|
)
|
||||||
|
return self.failure_response(
|
||||||
|
data=serializer.errors,
|
||||||
|
message='Malumot tahrirlanmadi'
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
|
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
responses={
|
||||||
|
204: base_serializers.SuccessResponseSerializer(),
|
||||||
|
400: base_serializers.BaseResponseSerializer(),
|
||||||
|
500: base_serializers.BaseResponseSerializer(),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
def delete(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(District, id=id, user=request.user)
|
||||||
|
obj.delete()
|
||||||
|
return self.success_response(message='Malumot ochirildi', status_code=204)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
# django
|
||||||
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
# rest framework
|
# rest framework
|
||||||
from rest_framework import generics, permissions
|
from rest_framework import generics, permissions
|
||||||
|
|
||||||
@@ -7,7 +10,7 @@ from drf_yasg.utils import swagger_auto_schema
|
|||||||
# shared
|
# shared
|
||||||
from core.apps.shared.models import Place
|
from core.apps.shared.models import Place
|
||||||
from core.apps.shared.serializers import base as base_serializer
|
from core.apps.shared.serializers import base as base_serializer
|
||||||
from core.apps.shared.serializers.place import PlaceSerializer, PlaceCreateSerializer
|
from core.apps.shared.serializers.place import PlaceSerializer, PlaceCreateSerializer, PlaceUpdateSerializer
|
||||||
from core.apps.shared.utils.response_mixin import ResponseMixin
|
from core.apps.shared.utils.response_mixin import ResponseMixin
|
||||||
|
|
||||||
# accounts
|
# accounts
|
||||||
@@ -66,4 +69,51 @@ class PlaceCreateApiView(generics.GenericAPIView, ResponseMixin):
|
|||||||
return self.success_response(data=PlaceSerializer(instance).data, message='malumot qoshildi')
|
return self.success_response(data=PlaceSerializer(instance).data, message='malumot qoshildi')
|
||||||
return self.failure_response(data=serializer.errors, message='malumot qoshilmadi')
|
return self.failure_response(data=serializer.errors, message='malumot qoshilmadi')
|
||||||
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')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class PlaceDeleteUpdateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = PlaceUpdateSerializer
|
||||||
|
queryset = Place.objects.all()
|
||||||
|
permission_classes = [permissions.IsAuthenticated]
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
responses={
|
||||||
|
200: base_serializer.SuccessResponseSerializer(),
|
||||||
|
400: base_serializer.BaseResponseSerializer(),
|
||||||
|
500: base_serializer.BaseResponseSerializer(),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
def patch(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(Place, id=id, user=request.user)
|
||||||
|
serializer = self.serializer_class(data=request.data, instance=obj)
|
||||||
|
if serializer.is_valid():
|
||||||
|
instance = serializer.save()
|
||||||
|
return self.success_response(
|
||||||
|
data=PlaceSerializer(instance).data,
|
||||||
|
message='Malumot tahrilandi'
|
||||||
|
)
|
||||||
|
return self.failure_response(
|
||||||
|
data=serializer.errors,
|
||||||
|
message='Malumot tahrirlanmadi'
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
|
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
responses={
|
||||||
|
204: base_serializer.SuccessResponseSerializer(),
|
||||||
|
400: base_serializer.BaseResponseSerializer(),
|
||||||
|
500: base_serializer.BaseResponseSerializer(),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
def delete(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(Place, id=id, user=request.user)
|
||||||
|
obj.delete()
|
||||||
|
return self.success_response(message='Malumot ochirildi', status_code=204)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
|
|||||||
Reference in New Issue
Block a user