Інтеграція 1С-Бітрікс з CoMagic
CoMagic — російська платформа наскрізної аналітики та колтрекінгу. Архітектурно відрізняється від Callibri більш детальною моделлю сесій: кожен візит розбивається на точки дотику, і в API доступний весь ланцюжок взаємодій до конверсії. Для інтеграції з Бітрікс це означає можливість передавати в угоду не просто utm_source, а повний customer journey. Другий ключовий блок — вихідні виклики через CoMagic SIP-телефонію прямо з картки CRM.
Що інтегруємо
Стандартний набір для повноцінної інтеграції:
- Webhook від CoMagic → створення ліда в Бітрікс CRM при цільовому дзвінку
- Передача
visitor_idз cookie CoMagic при відправці форм - CoMagic Data API → збагачення ліда даними про сесію
- Віджет дзвінка в Бітрікс CRM (click-to-call через CoMagic SIP)
CoMagic API: авторизація та базові виклики
CoMagic використовує JSON-RPC 2.0 поверх HTTPS. Авторизація — через логін/пароль, у відповідь отримуємо access_token.
namespace Local\CoMagic;
class ApiClient
{
private string $baseUrl = 'https://dataapi.comagic.ru/v2.0';
private ?string $accessToken = null;
private string $login;
private string $password;
public function __construct(string $login, string $password)
{
$this->login = $login;
$this->password = $password;
}
public function call(string $method, array $params = []): array
{
if (!$this->accessToken) {
$this->authenticate();
}
$payload = [
'jsonrpc' => '2.0',
'id' => uniqid('cm_', true),
'method' => $method,
'params' => array_merge(['access_token' => $this->accessToken], $params),
];
$ch = curl_init($this->baseUrl);
curl_setopt_array($ch, [
CURLOPT_POST => true,
CURLOPT_POSTFIELDS => json_encode($payload),
CURLOPT_RETURNTRANSFER => true,
CURLOPT_HTTPHEADER => ['Content-Type: application/json'],
CURLOPT_TIMEOUT => 10,
]);
$response = json_decode(curl_exec($ch), true);
curl_close($ch);
if (isset($response['error'])) {
throw new \RuntimeException('CoMagic API error: ' . $response['error']['message']);
}
return $response['result'] ?? [];
}
private function authenticate(): void
{
$payload = [
'jsonrpc' => '2.0',
'id' => 'auth',
'method' => 'login.user',
'params' => ['login' => $this->login, 'password' => $this->password],
];
$ch = curl_init($this->baseUrl);
curl_setopt_array($ch, [
CURLOPT_POST => true,
CURLOPT_POSTFIELDS => json_encode($payload),
CURLOPT_RETURNTRANSFER => true,
CURLOPT_HTTPHEADER => ['Content-Type: application/json'],
]);
$result = json_decode(curl_exec($ch), true);
curl_close($ch);
$this->accessToken = $result['result']['data']['access_token']
?? throw new \RuntimeException('CoMagic auth failed');
}
}
Webhook: обробка вхідного дзвінка
CoMagic підтримує сповіщення про події через callback URL. У налаштуваннях: Інтеграції → Webhook. Тип події — call_session_completed.
// /local/api/comagic-webhook.php
require_once($_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/main/include/prolog_before.php');
$data = json_decode(file_get_contents('php://input'), true);
// CoMagic підписує payload через HMAC-SHA256
$signature = $_SERVER['HTTP_X_COMAGIC_SIGNATURE'] ?? '';
$secret = \Bitrix\Main\Config\Option::get('local.comagic', 'webhook_secret');
$expected = hash_hmac('sha256', file_get_contents('php://input'), $secret);
if (!hash_equals($expected, $signature)) {
http_response_code(403);
exit;
}
$event = $data['event_type'] ?? '';
if ($event === 'call_session_completed') {
$processor = new \Local\CoMagic\CallProcessor();
$processor->handle($data['call_session']);
}
http_response_code(200);
Обробник дзвінка: створення/оновлення ліда
namespace Local\CoMagic;
class CallProcessor
{
public function handle(array $session): void
{
// Тільки цільові дзвінки створюємо як ліди
if (($session['is_lost_call'] ?? false) && ($session['duration_total'] ?? 0) < 10) {
return;
}
$phone = $this->normalizePhone($session['visitor_phone_number'] ?? '');
if (!$phone) {
return;
}
$existingLeadId = $this->findRecentLead($phone);
$fields = [
'TITLE' => 'Дзвінок CoMagic: ' . $phone,
'PHONE' => [['VALUE' => $phone, 'VALUE_TYPE' => 'WORK']],
'SOURCE_ID' => 'CALL',
'STATUS_ID' => 'NEW',
'UF_COMAGIC_ID' => (string)($session['id'] ?? ''),
'UF_UTM_SOURCE' => $session['utm_source'] ?? '',
'UF_UTM_MEDIUM' => $session['utm_medium'] ?? '',
'UF_UTM_CAMPAIGN' => $session['utm_campaign'] ?? '',
'UF_UTM_CONTENT' => $session['utm_content'] ?? '',
'UF_UTM_TERM' => $session['utm_term'] ?? '',
'COMMENTS' => $this->buildComment($session),
];
$lead = new \CCrmLead(false);
if ($existingLeadId) {
$lead->Update($existingLeadId, $fields, true);
} else {
$lead->Add($fields, true);
}
}
private function buildComment(array $session): string
{
return implode("\n", [
'CoMagic Session ID: ' . ($session['id'] ?? ''),
'Оператор: ' . ($session['employee_full_name'] ?? '—'),
'Тривалість: ' . ($session['duration_total'] ?? 0) . ' сек.',
'Джерело трафіку: ' . ($session['traffic_type'] ?? '—'),
'Сторінка входу: ' . ($session['site_domain_url'] ?? '—'),
'Теги: ' . implode(', ', $session['tags'] ?? []),
]);
}
}
Отримання даних візиту за visitor_id
CoMagic встановлює cookie comagic_visitor з ідентифікатором візиту. Це дає можливість на сервері запитати повні дані сесії — відвідані сторінки, канали, час на сайті.
// Серверний збагачувач ліда даними сесії CoMagic
class VisitorEnricher
{
private ApiClient $api;
public function enrichLead(int $leadId, string $visitorId): void
{
try {
$result = $this->api->call('visitors.get_visitor_info', [
'visitor_id' => $visitorId,
'date_from' => date('Y-m-d', strtotime('-1 day')),
'date_till' => date('Y-m-d'),
]);
$visitor = $result['data'][0] ?? null;
if (!$visitor) {
return;
}
$updateFields = [
'UF_CM_VISITOR_ID' => $visitorId,
'UF_CM_SESSION_COUNT' => (int)($visitor['sessions_count'] ?? 0),
'UF_CM_FIRST_SOURCE' => $visitor['first_session']['utm_source'] ?? '',
'UF_CM_LAST_SOURCE' => $visitor['last_session']['utm_source'] ?? '',
];
$lead = new \CCrmLead(false);
$lead->Update($leadId, $updateFields, true);
} catch (\RuntimeException $e) {
\CEventLog::Add([
'SEVERITY' => 'WARNING',
'AUDIT_TYPE_ID' => 'COMAGIC_ENRICH_FAIL',
'MODULE_ID' => 'local.comagic',
'DESCRIPTION' => $e->getMessage(),
]);
}
}
}
Click-to-call із картки CRM
CoMagic SIP дозволяє ініціювати вихідний дзвінок через API. Для Бітрікс реалізується через власний UI-обробник у картці ліда/угоди.
// REST-обробник для AJAX-запиту з картки CRM
public function initiateCall(int $leadId, string $operatorLogin): array
{
$lead = \CCrmLead::GetByID($leadId);
$phones = \CCrmFieldMulti::GetList(
[],
['ENTITY_ID' => 'LEAD', 'ELEMENT_ID' => $leadId, 'TYPE_ID' => 'PHONE']
);
$phoneRow = $phones->Fetch();
if (!$phoneRow) {
return ['success' => false, 'error' => 'No phone'];
}
$result = $this->api->call('calls.make_call', [
'virtual_phone_number' => \Bitrix\Main\Config\Option::get('local.comagic', 'virtual_number'),
'operator_login' => $operatorLogin,
'destination_number' => $phoneRow['VALUE'],
]);
return ['success' => true, 'call_id' => $result['data']['call_session_id'] ?? null];
}
Таблиця користувацьких полів
| Код | Прив'язка | Тип | Джерело |
|---|---|---|---|
| UF_COMAGIC_ID | Лід | string | Webhook |
| UF_CM_VISITOR_ID | Лід | string | Cookie |
| UF_CM_SESSION_COUNT | Лід | integer | Data API |
| UF_CM_FIRST_SOURCE | Лід | string | Data API |
| UF_CM_LAST_SOURCE | Лід | string | Data API |
| UF_UTM_SOURCE..TERM | Лід, Угода | string | Webhook / API |
Склад робіт
- Модуль
local.comagic: клієнт API, процесори подій, логер - Webhook-ендпоінт з верифікацією HMAC-підпису
- Створення/оновлення лідів у CRM за дзвінками та чатами
- JS-перехоплення форм для передачі visitor_id
- Серверне збагачення даними сесії через Data API
- (Опціонально) Click-to-call із картки CRM
- Дашборд: вкладка «CoMagic» у картці ліда з історією дотиків
Терміни: базова інтеграція (webhook → лід + UTM) — 1–2 тижні. Повна зшивка з multi-touch атрибуцією, click-to-call і вітриною даних — 4–6 тижнів.







