Інтеграція 1С-Бітрікс з Comagic

Наша компанія займається розробкою, підтримкою та обслуговуванням рішень на Бітрікс та Бітрікс24 будь-якої складності. Від простих односторінкових сайтів до складних інтернет-магазинів, CRM систем з інтеграцією 1С та телефонії. Досвід розробників підтверджено сертифікатами від вендора.
Послуги, які ми пропонуємо
Показано 1 з 1Усі 1626 послуг
Інтеграція 1С-Бітрікс з Comagic
Середній
~1-2 тижні
Часті запитання

Наші компетенції:

Етапи розробки

Останні роботи

  • image_website-b2b-advance_0.webp
    Розробка сайту компанії B2B ADVANCE
    1288
  • image_bitrix-bitrix-24-1c_fixper_448_0.webp
    Розробка веб-сайту для компанії ФІКСПЕР
    880
  • 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
    631
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Розробка на базі 1С Підприємство для компанії МИРСАНБЕЛ
    781
  • image_crm_dolbimby_434_0.webp
    Розробка сайту на CRM Бітрікс24 для компанії DOLBIMBY
    681
  • image_crm_technotorgcomplex_453_0.webp
    Розробка на базі Бітрікс24 для компанії ТЕХНОТОРГКОМПЛЕКС
    1010

Інтеграція 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 тижнів.