internal fixes
This commit is contained in:
@@ -271,17 +271,48 @@ class PlanChangeSerializer(serializers.Serializer):
|
||||
class LeadSerializer(serializers.ModelSerializer):
|
||||
route = serializers.PrimaryKeyRelatedField(queryset=Route.objects.all())
|
||||
moving_user = serializers.PrimaryKeyRelatedField(queryset=User.objects.all())
|
||||
moving_price = serializers.DecimalField(max_digits=10, decimal_places=2)
|
||||
|
||||
class Meta:
|
||||
model = Leads
|
||||
fields = ['route', 'moving_user', 'moving_price', 'moving_date', 'comment']
|
||||
|
||||
def validate_moving_date(self, value):
|
||||
if value < timezone.now().date():
|
||||
raise serializers.ValidationError("Дата перевозки не может быть в прошлом")
|
||||
return value
|
||||
try:
|
||||
if value < timezone.now().date():
|
||||
raise serializers.ValidationError("Дата перевозки не может быть в прошлом")
|
||||
return value
|
||||
except Exception as e:
|
||||
raise
|
||||
|
||||
def validate_moving_price(self, value):
|
||||
if value <= 0:
|
||||
raise serializers.ValidationError("Цена должна быть больше нуля")
|
||||
return value
|
||||
try:
|
||||
if isinstance(value, str):
|
||||
value = value.replace(',', '.')
|
||||
price = float(value)
|
||||
if price <= 0:
|
||||
raise serializers.ValidationError("Цена должна быть больше нуля")
|
||||
return price
|
||||
except (TypeError, ValueError) as e:
|
||||
raise serializers.ValidationError("Некорректный формат цены")
|
||||
|
||||
def validate(self, data):
|
||||
try:
|
||||
# проверяем что все обязательные поля присутствуют
|
||||
required_fields = ['route', 'moving_user', 'moving_price', 'moving_date']
|
||||
missing_fields = [field for field in required_fields if field not in data]
|
||||
if missing_fields:
|
||||
raise serializers.ValidationError(f"Отсутствуют обязательные поля: {', '.join(missing_fields)}")
|
||||
|
||||
# проверяем что пользователь не пытается откликнуться на свою заявку
|
||||
if data['route'].owner.id == data['moving_user'].id:
|
||||
raise serializers.ValidationError("Вы не можете откликнуться на собственную заявку")
|
||||
return data
|
||||
except Exception as e:
|
||||
raise
|
||||
|
||||
def to_internal_value(self, data):
|
||||
try:
|
||||
return super().to_internal_value(data)
|
||||
except Exception as e:
|
||||
raise
|
||||
Reference in New Issue
Block a user