internal fixes
This commit is contained in:
@@ -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
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user