40ad46c0263450177f87a9d66de3d2424e8df580
Problem: - wizard_plan comes in nested structure: edit_fields_parsed.wizard_plan_parsed - Old SQL looked for wizard_plan at root level (partial.p->'wizard_plan') - Result: wizard_plan was always NULL even though it existed in payload Solution: - Updated wizard_plan_parsed CTE to check multiple locations: 1. edit_fields_parsed.wizard_plan_parsed (already parsed object) ✅ 2. edit_fields_raw.body.wizard_plan (escaped JSON string) 3. Root level wizard_plan (backward compatibility) 4. Database fallback (if not in payload) - Updated wizard_answers_parsed CTE: 1. edit_fields_raw.body.wizard_answers (string) ✅ 2. edit_fields_parsed.body.wizard_answers (string) 3. Root level (backward compatibility) - Updated session_id, unified_id, contact_id, phone extraction: COALESCE() checks edit_fields_parsed.body and edit_fields_raw.body Input structure from n8n workflow form_get: { "payload_partial_json": { "edit_fields_parsed": { "wizard_plan_parsed": {...}, ← TARGET "body": { "session_id": "sess_xxx", ← ALSO HERE "unified_id": "usr_xxx", "wizard_answers": "{...}" } } } } Now: wizard_plan preserves correctly when uploading files ✅
🚀 Ticket Form Intake Platform
Платформа цифровой приёмки обращений для other.clientright.ru
- Backend: Python FastAPI (async)
- Frontend: React 18 + TypeScript
- Database: PostgreSQL + MySQL + Redis
- Queue: RabbitMQ
- Storage: S3 Timeweb Cloud
🎯 Быстрый старт
📍 Визуальный доступ:
После запуска доступны по адресам:
Frontend (форма):
http://147.45.146.17:5175/
Backend API:
http://147.45.146.17:8200/
API Документация (Swagger UI):
http://147.45.146.17:8200/docs ← Интерактивная!
Gitea (Git репозиторий):
http://147.45.146.17:3002/
🔧 Установка и запуск
Backend (FastAPI):
cd backend
# Создаём виртуальное окружение
python3 -m venv venv
source venv/bin/activate
# Устанавливаем зависимости
pip install -r requirements.txt
# Запускаем сервер
uvicorn app.main:app --reload --host 0.0.0.0 --port 8200
Frontend (React):
cd frontend
# Устанавливаем зависимости
npm install
# Запускаем dev сервер
npm run dev -- --host 0.0.0.0 --port 5175
📊 Архитектура
Поток данных:
React (5175) → FastAPI (8200) → [Redis, RabbitMQ, PostgreSQL]
↓
OCR Service (8001)
OpenRouter AI
FlightAware API
↓
PHP Bridge → Vtiger CRM
Что НЕ трогаем:
✅ CRM Vtiger (работает как работала)
✅ MySQL полисы (только READ)
✅ Существующий PHP код
🗄️ Базы данных
| База | Назначение | Хост |
|---|---|---|
| PostgreSQL | Логи, метрики, новые данные | 147.45.189.234:5432 |
| MySQL | Проверка полисов (READ) | localhost:3306 |
| Redis | Кеш, Rate Limiting | localhost:6379 |
📁 Структура проекта
ticket_form/
├─ backend/ ← Python FastAPI
│ ├─ app/
│ │ ├─ main.py
│ │ ├─ api/
│ │ ├─ services/
│ │ └─ models/
│ └─ requirements.txt
│
├─ frontend/ ← React TypeScript
│ ├─ src/
│ │ ├─ components/
│ │ ├─ pages/
│ │ └─ api/
│ └─ package.json
│
└─ .env ← Конфигурация
🔌 API Endpoints
Документы:
POST /api/v1/documents/upload- Загрузка в S3POST /api/v1/documents/scan- OCR + Vision
Рейсы:
GET /api/v1/flights/check- Проверка статуса
Обращения:
POST /api/v1/claims/submit- Создание обращения
Полисы:
GET /api/v1/policies/verify- Проверка полиса
🐛 Отладка
Логи:
# FastAPI
tail -f backend/logs/app.log
# PostgreSQL логи
SELECT * FROM logs ORDER BY created_at DESC LIMIT 50;
📝 Git
# Репозиторий
http://147.45.146.17:3002/negodiy/erv-platform
# Клонирование
git clone http://147.45.146.17:3002/negodiy/erv-platform.git
# Push изменений
git add .
git commit -m "Your message"
git push origin main
Автор: AI Assistant + Фёдор
Дата: 24.10.2025
Description
Languages
TypeScript
61.3%
Python
33.9%
Shell
1.8%
PLpgSQL
1.3%
HTML
1.3%
Other
0.4%