Интеграция 1С-Битрикс с Comagic

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Интеграция 1С-Битрикс с Comagic
Средняя
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1177
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    811
  • image_bitrix-bitrix-24-1c_development_of_an_online_appointment_booking_widget_for_a_medical_center_594_0.webp
    Разработка на базе Битрикс, Битрикс24, 1С для компании Development of an Online Appointment Booking Widget for a Medical Center
    564
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    747
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    655
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    976

Интеграция 1С-Битрикс с CoMagic

CoMagic — российская платформа сквозной аналитики и коллтрекинга. Архитектурно отличается от Callibri более детальной моделью сессий: каждый визит разбивается на точки касания, и в API доступна вся цепочка взаимодействий до конверсии. Для интеграции с Битрикс это означает возможность передавать в сделку не просто utm_source, а полный customer journey. Второй ключевой блок — исходящие вызовы через CoMagic SIP-телефонию прямо из карточки CRM.

Что интегрируем

Стандартный набор для полноценной интеграции:

  1. Webhook от CoMagic → создание лида в Битрикс CRM при целевом звонке
  2. Передача visitor_id из cookie CoMagic при отправке форм
  3. CoMagic Data API → обогащение лида данными о сессии
  4. Виджет звонка в Битрикс 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 недель.