internal fixes

This commit is contained in:
2025-05-24 15:12:37 +03:00
parent b755eda4b5
commit 88dc6932ec
8 changed files with 120 additions and 41 deletions

View File

@@ -198,10 +198,11 @@ class LeadViewSet(ViewSet):
@action(detail=False, methods=['post'])
@handle_exceptions
def send_lead(self, request, id):
def send_lead(self, request):
"""
Создание новой заявки на перевозку
"""
# добавляем текущего пользователя в данные
data = request.data.copy()
data['moving_user'] = request.user.id
@@ -209,40 +210,54 @@ class LeadViewSet(ViewSet):
# проверяем существование и доступность маршрута
try:
route = Route.objects.get(id=data.get('route'))
if route.owner == request.user:
if route.owner.id == request.user.id:
print("Error: User trying to respond to their own route")
return Response(
{"error": "Вы не можете откликнуться на собственную заявку"},
status=status.HTTP_400_BAD_REQUEST
)
except Route.DoesNotExist:
print("Route not found for ID:", data.get('route'))
return Response(
{"error": "Указанный маршрут не найден"},
status=status.HTTP_404_NOT_FOUND
)
serializer = LeadSerializer(data=data)
if serializer.is_valid():
lead = serializer.save()
# собираем ответ с данными о заявке для фронта
response_data = {
"status": "success",
"message": "Заявка успешно создана",
"data": {
"id": lead.id,
"route_id": lead.route.id,
"moving_price": lead.moving_price,
"moving_date": lead.moving_date,
is_valid = serializer.is_valid()
if is_valid:
try:
lead = serializer.save()
# собираем ответ с данными о заявке для фронта
response_data = {
"status": "success",
"message": "Заявка успешно создана",
"data": {
"id": lead.id,
"route_id": lead.route.id,
"moving_price": lead.moving_price,
"moving_date": lead.moving_date,
}
}
}
return Response(response_data, status=status.HTTP_201_CREATED)
return Response(
{
"status": "error",
"message": "Ошибка валидации данных",
"errors": serializer.errors
},
status=status.HTTP_400_BAD_REQUEST
)
return Response(response_data, status=status.HTTP_201_CREATED)
except Exception as e:
return Response(
{
"status": "error",
"message": "Ошибка при сохранении заявки",
"error": str(e)
},
status=status.HTTP_500_INTERNAL_SERVER_ERROR
)
else:
return Response(
{
"status": "error",
"message": "Ошибка валидации данных",
"errors": serializer.errors
},
status=status.HTTP_400_BAD_REQUEST
)