- Добавлены unified_id и contact_id в TicketFormDescriptionRequest - Исправлен CODE_MERGE_PROJECT_TO_SESSION.js - теперь сохраняются ВСЕ данные из body.other - Добавлен fallback на получение other из Webhook напрямую - Генерация новой session_id при создании новой жалобы (сохраняя авторизацию) - Добавлен SQL_SELECT_CONTACT_WITH_CUSTOM_FIELDS.sql для CRM контактов - Создан SESSION_LOG_2025-11-25.md с документацией сессии
5.3 KiB
5.3 KiB
Обновление Response Node в n8n: Добавление unified_id
Проблема
В текущем Response Node отсутствует unified_id, который необходим для поиска черновиков на фронтенде.
Решение
Шаг 1: Убедитесь, что есть нода user_get
Это PostgreSQL нода, которая выполняет SQL запрос из SQL_FIND_OR_CREATE_USER_WEB_FORM.sql.
Настройки ноды:
- Name:
user_get(или другое имя, но должно совпадать в коде) - Operation: Execute Query
- Query: SQL из
SQL_FIND_OR_CREATE_USER_WEB_FORM.sql - Parameters:
$1 = {{$json.phone}}(нормализованный телефон)
Результат ноды:
{
"unified_id": "usr_90599ff2-ac79-4236-b950-0df85395096c",
"user_id": 1
}
Шаг 2: Обновите Code Node перед Response
Вариант 1: Простая версия
// ========================================
// Code Node: Формирование Response для фронта
// (перед финальной Response нодой)
// ========================================
const claimResult = $node["CreateWebContact"].json.result;
const sessionData = JSON.parse($('Code in JavaScript1').first().json.redis_value);
const userData = $node["user_get"].json; // ← Данные из PostgreSQL
return {
success: true,
result: {
claim_id: sessionData.claim_id,
contact_id: sessionData.contact_id,
project_id: sessionData.project_id,
// Unified ID из PostgreSQL (обязательно!)
unified_id: userData.unified_id, // ← ДОБАВЛЕНО!
ticket_id: claimResult.ticket_id,
ticket_number: claimResult.ticket_number,
title: claimResult.title,
category: claimResult.category,
status: claimResult.status,
event_type: sessionData.event_type,
current_step: sessionData.current_step,
updated_at: sessionData.updated_at,
is_new_contact: claimResult.is_new_contact || false
}
};
Вариант 2: Безопасная версия с проверками
// ========================================
// Code Node: Формирование Response для фронта (безопасная версия)
// ========================================
const claimResult = $node["CreateWebContact"]?.json?.result || {};
const sessionDataItem = $('Code in JavaScript1')?.first();
const sessionData = sessionDataItem?.json?.redis_value
? JSON.parse(sessionDataItem.json.redis_value)
: {};
const userData = $node["user_get"]?.json || {}; // ← Данные из PostgreSQL
// Проверяем наличие unified_id (критически важно!)
if (!userData.unified_id) {
console.error('❌ ОШИБКА: unified_id не получен из ноды user_get!');
// Можно либо выбросить ошибку, либо продолжить без unified_id (не рекомендуется)
}
return {
success: true,
result: {
claim_id: sessionData.claim_id || claimResult.claim_id,
contact_id: sessionData.contact_id || claimResult.contact_id,
project_id: sessionData.project_id,
// Unified ID из PostgreSQL (обязательно!)
unified_id: userData.unified_id, // ← ДОБАВЛЕНО!
ticket_id: claimResult.ticket_id,
ticket_number: claimResult.ticket_number,
title: claimResult.title,
category: claimResult.category,
status: claimResult.status,
event_type: sessionData.event_type,
current_step: sessionData.current_step || 1,
updated_at: sessionData.updated_at || new Date().toISOString(),
is_new_contact: claimResult.is_new_contact || false
}
};
Порядок нод в workflow
- Webhook → получает
{phone, session_id, form_id} - Code in JavaScript1 → получает данные из Redis
- CreateWebContact → создает/находит контакт в CRM
- user_get (PostgreSQL) → находит/создает пользователя → возвращает
unified_id - Code Node (этот код) → формирует финальный ответ
- Response → возвращает ответ фронтенду
Важно!
- Имя ноды: Убедитесь, что имя ноды PostgreSQL совпадает с
$node["user_get"]в коде - unified_id обязателен: Без него фронтенд не сможет найти черновики
- Проверка: Добавьте проверку на наличие
unified_idперед возвратом ответа
Ожидаемый формат ответа
{
"success": true,
"result": {
"claim_id": "CLM-2025-11-19-7O55SP",
"contact_id": "398644",
"project_id": "12345",
"unified_id": "usr_90599ff2-ac79-4236-b950-0df85395096c", // ← ОБЯЗАТЕЛЬНО!
"ticket_id": "45678",
"ticket_number": "HD001234",
"title": "Заявка",
"category": "Категория",
"status": "Новая",
"event_type": null,
"current_step": 1,
"updated_at": "2025-11-19T15:15:07.323Z",
"is_new_contact": false
}
}