goal_signal_derived
Что означает
Универсальная цель: клик, скачивание, заявка, регистрация, бронь — не зашита в SDK.
Goal-признаки нормализуют conversion-like сигналы из client track API, page rules и импортов.
Исходные события
- click
- form_submit_attempt
- custom_track
page_view success rulesmapping config
Алгоритм
- Триггер: Когда raw событие соответствует настроенной цели.
- Расчет: goal_code, goal_type, source_event_id, value_bucket optional.
- Приоритет:
P0; рассчитывается сервером:Да. - Не просите SDK отправлять
goal_signal_derivedнапрямую: сервер выводит это событие из принятых source-событий или безопасных импортов.
Текущий статус реализации: отправляется текущим backend/app/services/derived_processor.py, когда присутствуют нужные source-сигналы.
Формат хранения
Хранится в sf_server_derived_events с derived_type = "goal_signal_derived", derived_ts, source_event_id, если строка связана с конкретным source-событием, а также batch_id, session_id, mapping_version и payload_json.
Для агрегатов уровня сессии source_event_id может быть пустым; последнее состояние сессии также отражается в sf_session_snapshots, когда это применимо.
Пример payload
{
"derived_type": "goal_signal_derived",
"source_event_id": "evt_example_or_empty",
"mapping_version": "map_active",
"payload": {
"goal_code": "example",
"goal_type": "example",
"source_event_id": "example",
"value_bucket": "example"
}
}Примеры и допустимые значения из Excel: goal_type: lead,signup,download,booking,application,purchase,custom.
Крайние случаи
Если нет уверенного источника — не создавать или status=suspect.
Если обязательных checkpoints не хватает, снижайте confidence или помечайте payload как partial. Никогда не синтезируйте положительный intent-сигнал только из-за отсутствия события.
Дашборд
Ожидаемое окно live-debug: Цели и конверсии.
Если строка относится к загруженной сессии, она также должна находиться в окне Лента сессии.
Использование в ML
goal_reached_flag, auxiliary labels.
Используйте стабильные codes и buckets вместо сырого текста, сырых URL или строк из DOM. Отсутствующие значения должны быть явными (not_available, unknown, partial), чтобы CatBoost отличал отсутствие сигнала от отрицательного сигнала.
Использование в детекции ботов
Голы от ботов не должны попадать в clean training labels без bot filter.
Логика детекции ботов должна комбинировать этот признак с независимыми поведенческими сигналами; эта страница не разрешает fingerprinting, cookies, canvas/WebGL/audio probes или сырые значения форм.
QA-проверки checklist
- Сгенерируйте перечисленные source-события в одной сессии.
- Запустите server-derived обработку для этой сессии.
- Проверьте, что
sf_server_derived_eventsсодержит строкуderived_type = "goal_signal_derived"или что событие явно помечено как еще не реализованное. - Откройте окно live-debug дашборда
Цели и конверсиии проверьте, что строка ссылается обратно на эту страницу. - Проверьте, что
payload_jsonсодержит только безопасные поля из списка выше и не содержит сырые ПДн, query string, cookies или значения форм.