Files
aiform_prod/docs/CODE_CREATE_WEB_CONTACT_FIXED.js
AI Assistant 3621ae6021 feat: Session persistence with Redis + Draft management fixes
- Implement session management API (/api/v1/session/create, verify, logout)
- Add session restoration from localStorage on page reload
- Fix session_id priority when loading drafts (use current, not old from DB)
- Add unified_id and claim_id to wizard payload sent to n8n
- Add Docker volume for frontend HMR (Hot Module Replacement)
- Add comprehensive session logging for debugging

Components updated:
- backend/app/api/session.py (NEW) - Session management endpoints
- backend/app/main.py - Include session router
- frontend/src/components/form/Step1Phone.tsx v2.0 - Create session after SMS
- frontend/src/pages/ClaimForm.tsx v3.8 - Session restoration & priority fix
- frontend/src/components/form/StepWizardPlan.tsx v1.4 - Add unified_id/claim_id
- docker-compose.yml - Add frontend volume for live reload

Session flow:
1. User verifies phone -> session created in Redis (24h TTL)
2. session_token saved to localStorage
3. Page reload -> session restored automatically
4. Draft selected -> current session_id used (not old from DB)
5. Wizard submit -> unified_id, claim_id, session_id sent to n8n
6. Logout -> session removed from Redis & localStorage

Fixes:
- Session token not persisting after page reload
- unified_id missing in n8n webhook payload
- Old session_id from draft overwriting current session
- Frontend changes requiring container rebuild
2025-11-20 18:31:42 +03:00

45 lines
1.4 KiB
JavaScript

// Парсим результат CreateWebContact
const rawResult = $node["CreateWebContact"].json.result;
const contactData = JSON.parse(rawResult); // {"contact_id": "396625", "is_new": false}
const phone = $('Edit Fields').first().json.phone;
// Получаем session_id
const session_id = $('Edit Fields').first().json.session_id;
// Генерируем claim_id
const date = new Date().toISOString().split('T')[0];
const randomId = Math.random().toString(36).substr(2, 6).toUpperCase();
const claim_id = `CLM-${date}-${randomId}`;
// Формируем session для Redis
const sessionData = {
claim_id: claim_id,
contact_id: contactData.contact_id, // ← распарсенный ID
phone: phone,
is_new_contact: contactData.is_new, // ← флаг нового контакта
status: "draft",
current_step: 1,
created_at: new Date().toISOString(),
updated_at: new Date().toISOString(),
voucher: null,
event_type: null,
documents: {},
email: null,
bank_name: null
};
return {
session: session_id,
session_id: session_id, // Добавляем для совместимости
claim_id: claim_id,
contact_id: contactData.contact_id,
is_new_contact: contactData.is_new,
phone: phone,
redis_key: `session:${session_id}`, // ✅ Исправлено: используем session_id вместо session
redis_value: JSON.stringify(sessionData),
ttl: 604800
};