Database changes: - Add unified_id, contact_id, phone columns to clpr_claims table - Create indexes for fast lookup by these fields - Migrate existing data from payload to new columns - SQL migration: docs/SQL_ALTER_CLPR_CLAIMS_ADD_FIELDS.sql SQL improvements: - Simplify claimsave query: remove complex claim_lookup logic - Use UPSERT (INSERT ON CONFLICT) with known claim_id - Always return claim (fix NULL issue) - Store unified_id, contact_id, phone directly in table columns - SQL: docs/SQL_CLAIMSAVE_UPSERT_SIMPLE.sql Workflow enhancements: - Add branch for form submissions WITHOUT files - Create 6 new nodes: extract, prepare, save, redis, respond - Separate flow for has_files=false in IF node - Instructions: docs/N8N_FORM_GET_NO_FILES_INSTRUCTIONS.md - Node config: docs/N8N_FORM_GET_NO_FILES_BRANCH.json Migration stats: - Total claims: 81 - With unified_id: 77 - Migrated from payload: 2 Next steps: 1. Add 6 nodes to n8n workflow form_get (ID: 8ZVMTsuH7Cmw7snw) 2. Connect TRUE branch of IF node to extract_webhook_data_no_files 3. Test form submission without files 4. Verify PostgreSQL save and Redis event
3.1 KiB
3.1 KiB
Формат ответа n8n после проверки телефона
Текущий формат (неполный)
{
"success": true,
"result": {
"claim_id": "CLM-2025-11-19-7O55SP",
"contact_id": "398644",
"event_type": null,
"current_step": 1,
"updated_at": "2025-11-19T15:15:07.323Z"
}
}
Требуемый формат (с unified_id)
{
"success": true,
"result": {
"claim_id": "CLM-2025-11-19-7O55SP",
"contact_id": "398644",
"unified_id": "usr_90599ff2-ac79-4236-b950-0df85395096c", // ← ДОБАВИТЬ!
"event_type": null,
"current_step": 1,
"updated_at": "2025-11-19T15:15:07.323Z",
"is_new_contact": false // опционально
}
}
Где добавить unified_id в n8n workflow
Шаг 1: После CreateWebContact
- Получен
contact_idиз CRM - Есть
phoneиз запроса
Шаг 2: PostgreSQL Node - Find or Create User
- Выполнить SQL запрос из
SQL_FIND_OR_CREATE_USER_WEB_FORM.sql - Параметр:
$1 = {{$json.phone}}(нормализованный телефон) - Результат:
unified_idиuser_id
Шаг 3: Response Node или Code Node
Вернуть ответ с unified_id:
return {
success: true,
result: {
claim_id: $('CreateWebContact').item.json.claim_id || $('GenerateClaimId').item.json.claim_id,
contact_id: $('CreateWebContact').item.json.contact_id,
unified_id: $('PostgreSQL_FindOrCreateUser').item.json.unified_id, // ← ВАЖНО!
event_type: null,
current_step: 1,
updated_at: new Date().toISOString(),
is_new_contact: $('CreateWebContact').item.json.is_new_contact || false
}
};
Важно!
- unified_id обязателен - frontend использует его для поиска черновиков
- Формат unified_id:
usr_{UUID}(например,usr_90599ff2-ac79-4236-b950-0df85395096c) - Если unified_id отсутствует - frontend не сможет найти черновики пользователя
- При создании/обновлении черновика - обязательно заполнять
clpr_claims.unified_id = unified_id
Проверка в frontend
Frontend уже готов принимать unified_id:
// Step1Phone.tsx, строка 132
updateFormData({
phone,
smsCode: code,
contact_id: result.contact_id,
unified_id: result.unified_id, // ✅ Уже ожидается!
claim_id: result.claim_id,
is_new_contact: result.is_new_contact
});
Пример полного workflow в n8n
- Webhook → получает
{phone, session_id, form_id} - CreateWebContact → создает/находит контакт в CRM → возвращает
contact_id - GenerateClaimId → генерирует
claim_id(если нужно) - PostgreSQL: Find or Create User → выполняет SQL запрос → возвращает
unified_id - Response → возвращает полный ответ с
unified_id