Интеграция 1С-Битрикс с Яндекс Маршрутизация

Наша компания занимается разработкой, поддержкой и обслуживанием решений на Битрикс и Битрикс24 любой сложности. От простых одностраничных сайтов до сложных интернет магазинов, CRM систем с интеграцией 1С и телефонии. Опыт разработчиков подтвержден сертификатами от вендора.
Предлагаемые услуги
Показано 1 из 1 услугВсе 1626 услуг
Интеграция 1С-Битрикс с Яндекс Маршрутизация
Средняя
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1236
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    844
  • 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
    582
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Разработка на базе 1С Предприятие для компании МИРСАНБЕЛ
    749
  • image_crm_dolbimby_434_0.webp
    Разработка сайта на CRM Битрикс24 для компании DOLBIMBY
    657
  • image_crm_technotorgcomplex_453_0.webp
    Разработка на базе Битрикс24 для компании ТЕХНОТОРГКОМПЛЕКС
    980

Интеграция 1С-Битрикс с Яндекс Маршрутизация

Яндекс Маршрутизация (Яндекс.Курьер API) — российский сервис оптимизации логистики с учётом реального трафика, временных окон и ограничений транспортных средств. API позволяет создавать рейсы, назначать заказы водителям и получать трекинг в реальном времени. Интеграция с Битрикс даёт полный цикл: от заказа на сайте до уведомления клиента о доставке.

Регистрация в Яндекс.Курьер

Для работы с API нужно:

  1. Зарегистрировать компанию в кабинете courier.yandex.ru
  2. Получить COMPANY_ID — числовой идентификатор компании
  3. Получить OAuth-токен через Яндекс OAuth для доступа к API
  4. Настроить склад (депо) — точку отправления с координатами

Базовый URL API: https://courier.yandex.ru/api/v1/companies/{company_id}/

Создание рейса через API

Рейс (route) в Яндекс.Маршрутизации — это набор заказов, назначенных на одно транспортное средство. Создание рейса:

class YandexCourierClient
{
    private string $baseUrl;
    private string $oauthToken;
    private int    $companyId;

    public function __construct()
    {
        $this->baseUrl    = 'https://courier.yandex.ru/api/v1';
        $this->oauthToken = \Bitrix\Main\Config\Option::get('main', 'YANDEX_COURIER_TOKEN');
        $this->companyId  = (int)\Bitrix\Main\Config\Option::get('main', 'YANDEX_COURIER_COMPANY_ID');
    }

    public function createRoute(array $depot, array $vehicle, array $orders): array
    {
        $payload = [
            'number'    => 'BX-' . date('Ymd') . '-' . uniqid(),
            'depot'     => [
                'id'    => $depot['id'],
                'point' => ['lat' => $depot['lat'], 'lon' => $depot['lon']],
                'time_window' => [$depot['open'], $depot['close']],
            ],
            'vehicle'   => [
                'id'          => $vehicle['id'],
                'max_weight'  => $vehicle['max_weight'],
                'max_volume'  => $vehicle['max_volume'],
            ],
            'orders'    => $this->formatOrders($orders),
        ];

        $http = new \Bitrix\Main\Web\HttpClient();
        $http->setHeader('Authorization', 'OAuth ' . $this->oauthToken);
        $http->setHeader('Content-Type', 'application/json');

        $result = $http->post(
            "{$this->baseUrl}/companies/{$this->companyId}/routes",
            json_encode($payload, JSON_UNESCAPED_UNICODE)
        );

        if ($http->getStatus() !== 200) {
            throw new \RuntimeException('Yandex Courier API error: ' . $result);
        }

        return json_decode($result, true);
    }

    private function formatOrders(array $orders): array
    {
        return array_map(fn($o) => [
            'number'          => (string)$o['bitrix_order_id'],
            'point'           => ['lat' => $o['lat'], 'lon' => $o['lon']],
            'address'         => $o['address'],
            'time_window'     => [$o['time_from'], $o['time_to']],
            'weight_kg'       => $o['weight'],
            'customer_name'   => $o['customer_name'],
            'customer_phone'  => $o['customer_phone'],
            'service_duration' => 300,
        ], $orders);
    }
}

Трекинг водителей и заказов

Яндекс.Курьер предоставляет вебхуки для отслеживания событий. Зарегистрируйте вебхук в настройках компании:

$http->post("{$this->baseUrl}/companies/{$this->companyId}/webhooks", json_encode([
    'url'    => 'https://your-site.ru/bitrix/yandex_courier_webhook.php',
    'events' => ['order_status_changed', 'route_started', 'route_finished'],
]));

Обработчик вебхука:

// /bitrix/yandex_courier_webhook.php
\Bitrix\Main\Loader::includeModule('sale');

$data = json_decode(file_get_contents('php://input'), true);

if ($data['event'] === 'order_status_changed') {
    $orderId = (int)$data['order']['number'];  // мы передавали bitrix_order_id как number
    $status  = $data['order']['status'];

    $statusMap = [
        'confirmed'    => 'TD',
        'in_progress'  => 'OD',
        'finished'     => 'F',
        'cancelled'    => 'CF',
    ];

    $bitrixStatus = $statusMap[$status] ?? null;

    if ($orderId && $bitrixStatus) {
        $order = \Bitrix\Sale\Order::load($orderId);
        $order?->setField('STATUS_ID', $bitrixStatus);
        $order?->save();

        if ($status === 'finished') {
            \Bitrix\Main\Mail\Event::send([
                'EVENT_NAME' => 'SALE_ORDER_DELIVERED',
                'LID'        => SITE_ID,
                'C_FIELDS'   => ['ORDER_ID' => $orderId],
            ]);
        }
    }
}

http_response_code(200);

Расчёт координат из адресов

Яндекс.Маршрутизация требует координаты (lat/lon), а не текстовые адреса. Для геокодирования используйте Яндекс Геокодер API при оформлении заказа:

function geocodeAddress(string $address): ?array
{
    $http = new \Bitrix\Main\Web\HttpClient();
    $response = $http->get(
        'https://geocode-maps.yandex.ru/1.x/?' . http_build_query([
            'apikey'   => YANDEX_GEOCODER_API_KEY,
            'geocode'  => $address,
            'format'   => 'json',
            'results'  => 1,
        ])
    );

    $data = json_decode($response, true);
    $pos  = $data['response']['GeoObjectCollection']['featureMember'][0]
            ['GeoObject']['Point']['pos'] ?? null;

    if ($pos) {
        [$lon, $lat] = explode(' ', $pos);
        return ['lat' => (float)$lat, 'lon' => (float)$lon];
    }

    return null;
}

Координаты сохраняются в пользовательские свойства заказа UF_DELIVERY_LAT и UF_DELIVERY_LON.

Ссылка для клиента на отслеживание

Яндекс.Курьер генерирует публичную ссылку на трекинг посылки. Получите её через API и отправьте клиенту:

$trackingUrl = $routeResponse['tracking_url'] ?? null;
if ($trackingUrl) {
    $order->setField('UF_TRACKING_URL', $trackingUrl);
    // Отправить в письме клиенту
}

Сроки выполнения

Этап Сроки
Базовая интеграция: создание рейсов 3–4 дня
Вебхуки и обновление статусов 2–3 дня
Геокодирование при оформлении 1–2 дня
Административный интерфейс управления рейсами 3–5 дней
Тестирование и отладка 2–3 дня

Что настраиваем

  • Класс YandexCourierClient с методами создания рейсов и управления заказами
  • Агент сборки заказов на день и автоматического создания рейсов
  • Геокодирование адресов при оформлении заказа с сохранением в свойства UF_DELIVERY_LAT/LON
  • Вебхук-обработчик для обновления статусов заказов Битрикс
  • Отправку клиенту ссылки на трекинг посылки при старте рейса