- Исправлена потеря документов при обновлении черновика (SQL объединяет вместо перезаписи) - Исправлено определение типа документа (приоритет field_label над field_name) - Исправлены дубликаты в documents_meta и documents_uploaded - Добавлена передача group_index с фронтенда для правильного field_name - Исправлены все документы в таблице clpr_claim_documents с правильными field_name - Обновлены SQL запросы: claimsave и claimsave_final для нового флоу - Добавлена поддержка multi-file upload для одного документа - Исправлены дубликаты в списке загруженных документов на фронтенде Файлы: - SQL: SQL_CLAIMSAVE_FIXED_NEW_FLOW.sql, SQL_CLAIMSAVE_FINAL_FIXED_NEW_FLOW_WITH_UPLOADED.sql - n8n: N8N_CODE_PROCESS_UPLOADED_FILES_FIXED.js (поддержка group_index) - Backend: documents.py (передача group_index в n8n) - Frontend: StepWizardPlan.tsx (передача group_index, исправление дубликатов) - Скрипты: fix_claim_documents_field_names.py, fix_documents_meta_duplicates.py Результат: документы больше не теряются, имеют правильные типы и field_name
78 lines
3.2 KiB
Python
78 lines
3.2 KiB
Python
"""
|
||
Pydantic модели для API
|
||
"""
|
||
from pydantic import BaseModel, Field, field_validator
|
||
from typing import Optional, List
|
||
from datetime import date
|
||
|
||
|
||
class SMSSendRequest(BaseModel):
|
||
"""Запрос на отправку SMS кода"""
|
||
phone: str = Field(..., description="Номер телефона в формате +79001234567")
|
||
|
||
@field_validator('phone')
|
||
@classmethod
|
||
def validate_phone(cls, v: str) -> str:
|
||
# Убираем все кроме цифр и +
|
||
clean = ''.join(c for c in v if c.isdigit() or c == '+')
|
||
if not clean.startswith('+'):
|
||
clean = '+' + clean
|
||
if len(clean) != 12: # +7 + 10 цифр
|
||
raise ValueError('Неверный формат телефона')
|
||
return clean
|
||
|
||
|
||
class SMSVerifyRequest(BaseModel):
|
||
"""Запрос на проверку SMS кода"""
|
||
phone: str = Field(..., description="Номер телефона")
|
||
code: str = Field(..., min_length=6, max_length=6, description="6-значный код")
|
||
|
||
|
||
class ClaimCreateRequest(BaseModel):
|
||
"""Запрос на создание заявки"""
|
||
# Шаг 1: Основная информация
|
||
phone: str
|
||
email: Optional[str] = None
|
||
inn: Optional[str] = None
|
||
policy_number: str
|
||
policy_series: Optional[str] = None
|
||
|
||
# Шаг 2: Данные о происшествии
|
||
incident_date: Optional[str] = None
|
||
incident_description: Optional[str] = None
|
||
transport_type: Optional[str] = None # "air", "train", "bus", etc.
|
||
|
||
# Шаг 3: Данные для выплаты
|
||
payment_method: str = "sbp" # "sbp", "card", "bank_transfer"
|
||
bank_name: Optional[str] = None
|
||
card_number: Optional[str] = None
|
||
account_number: Optional[str] = None
|
||
|
||
# Файлы (UUID после загрузки)
|
||
uploaded_files: Optional[List[str]] = []
|
||
|
||
# Метаданные
|
||
source: str = "web_form"
|
||
|
||
|
||
class ClaimResponse(BaseModel):
|
||
"""Ответ после создания заявки"""
|
||
success: bool
|
||
claim_id: Optional[str] = None
|
||
claim_number: Optional[str] = None
|
||
message: str
|
||
|
||
|
||
class TicketFormDescriptionRequest(BaseModel):
|
||
"""Отправка свободного описания проблемы (Ticket Form)"""
|
||
session_id: str = Field(..., description="ID клиентской сессии")
|
||
claim_id: Optional[str] = Field(None, description="ID заявки (если уже создана)")
|
||
phone: Optional[str] = Field(None, description="Номер телефона заявителя")
|
||
email: Optional[str] = Field(None, description="Email заявителя")
|
||
unified_id: Optional[str] = Field(None, description="Unified ID пользователя из PostgreSQL")
|
||
contact_id: Optional[str] = Field(None, description="Contact ID пользователя в CRM")
|
||
problem_description: str = Field(..., min_length=10, description="Свободное описание ситуации")
|
||
source: str = Field("ticket_form", description="Источник события")
|
||
channel: Optional[str] = Field(None, description="Переопределение Redis канала (опционально)")
|
||
|