Интеграция с API Деловые Линии
Доброго времени друзья! Недавно я реализовал функционал интеграции CMS/CRM системы(объединяющей в себе и сайта, и бизнес логику связанную с работой всей компании) одного из своих клиентов с API транспортной компании Деловые Линии, что позволило существенно сократить время на работу с отправлениями грузов, оформлением заявок, отслеживанием, а также работы с отчетами. Для последних я также разработал автоматизированную систему ведения статистики с возможность просмотра данных в разных срезах. Далее обо всем подробнее.
Реализованный функционал
В рамках интеграции CMS/CRM системы с API Деловые Линии, был реализован функционал представляющий собой личный кабинет со следующими разделами:
- Калькулятор расчета стоимости и сроков доставки груза, с автоматической подгрузкой данных из CRM системы, об отправителе и получателе, а также параметров самого груза;
- Оформление заявок из личного кабинета, также с автоматической подгрузкой данных из CRM системы, об отправителе и получателе, а также параметров самого груза;
- Поиск заказов в базе данных Деловых Линий по номеру отправления, дате или диапазону дат;
- Работа со справочниками: терминалы и ПВЗ, использование кодов КЛАДР, поиск городов;
- Работа с отчетами, получение данных о грузе(как отправленном от нас, так и поступающем к нам). Получение данных из отчетов о весе, стоимости, сроках. Сохранение данных в систему CRM. Ведение собственной статистики.
Реализованный функционал позволил существенно сократить время на оформление заявок на оправку грузов, из-за автоматического внесения данных об отправителе, получателе и параметрах груза в форму заявки. Ранее приходилось вносить данные вручную, на что уходило достаточно много времени работы менеджера. При большом количестве отправлений, ежедневно на эту простую операцию требовалось 1-2 часа рабочего времени.
Также автоматизация обработки отчетов, позволила собирать и структурировать данные(с возможностью выборки по разным срезам) о грузах направляющихся к нам, в том числе ведение статистики по месячным финансовым затратам на оплату приходящих грузов.
Описание API
На сайте компании Деловые Линии, в разделе для разработчика, предоставлена полная документация по работе с API, описаны все методы(в том числе на английском языке) с передаваемыми и получаемыми в ответ параметрами. Поддерживаются два формате передачи данных XML и JSON. Доступно два пространства методов: публичные методы и методы доступные только авторизированным пользователям. Для авторизации используется APIKey плюс логин и пароль от личного кабинета. Для получения APIKey, необходимо зарегистрироваться на сайте Деловых линий в разделе для разработчика, указав данные о своей компании и для чего вы будите использовать API.
На моя взгляд интересным является то, что одну учетную запись(APIKey и параметры доступа в личный кабинет) можно использовать для работы с разными контрагентами, что позволяет оформлять заказы от имени разных отправителей(компаний). В API для работы с контрагентами также предусмотрен метод, позволяющий получать список контрагентов(предварительно закрепленных в личном кабинете).
Пример запроса и ответа в формате JSON:
Авторизация пользователя
Адрес метода: https://api.dellin.ru/v3/auth/login.json
Запрос:
{ "appkey":"00000000-0000-0000-0000-000000000000", "login":"info@info.ru", "password":"Password1" } |
Ответ:
{ "metadata":{ "status":200, "generated_at":"2015-06-18 12:37:28" }, "data":{ "sessionID":"00000000-0000-0000-0000-000000000000" } } |
Для работы с API Деловые Линии, на начальном этапе достаточно простого PHP класса:
<? class DLClient { private $session; function __construct($appKey){ $appKey?$this->appKey = $appKey:die("No app key given"); } function auth($login, $password){ $url = 'https://api.dellin.ru/v1/customers/login.json'; $body = array( 'login' => $login, 'password' => $password, 'appKey' => $this->appKey ); $opts = array( 'http' => array( 'method' => 'POST', 'header' => "Content-Type: application/json", 'content' => json_encode($body) ) ); $result = file_get_contents($url, false, stream_context_create($opts)); $res = (array)json_decode($result); $this->session = $res['sessionID']; } function request($op, $params = array()){ $url = 'https://api.dellin.ru/v1/'.$op.'.json'; $body = $params; $body["appKey"] = $this->appKey; if (isset($this->session)){ $body["sessionID"] = $this->session; } $opts = array( 'http' => array( 'method' => 'POST', 'header' => "Content-Type: application/json", 'content' => json_encode($body) ) ); $result = file_get_contents($url, false, stream_context_create($opts)); $this->result = (array)json_decode($result); } } // Пример использования $appKey = '111'; $client = new DLClient($appKey); $client->request('public/tracker', array('docId' => '13-00083508789')); print_r ($client->result); // работаем с массивом $client->result // Если нужна авторизация: $client->auth('login', 'pass'); $client->request('public/tracker', array('docId' => '13-00083508789')); // работаем с массивом $client->result |
Как видите есть возможность работы с методами где нужна авторизация, а также с методами без неё. В качестве названия метода указывается часть его URL, описанного в документации. Например «public/calculator_sf», для метода: «Калькулятор услуги Доставка до адреса»
с URL «http://api.dellin.ru/v1/public/calculator_sf.json». В документации есть готовые примеры на Ruby и Python.
Пожалуй это самый компактный PHP SDK для интеграции с API какой я когда либо встречал;)
Особенности
К особенностям можно отнести:
- Ряд методов(например работа с отчетами), доступных только для авторизированных пользователей, активируется по дополнительному запросу в службу поддержки(время рассмотрения может занять до нескольких дней);
- Имеются ограничения на количество запросов к API в час/минуту: 1600/45. Плюс рекомендуемый тайм-аут соединения — 10 секунд. Если ему следовать, то количество запросов в минуту снижается до 6-10. При реализации крупных проектов, работающих с множеством контрагентов, возможно данные лимиты будут малы, поэтому потребуется дополнительное согласование их со службой поддержки.
Заключение
Разработанный мною функционал для CMS/CRM системы, написан на языках PHP и JavaScript (стандартный стек для веб), и может быть интегрирован на любую веб-платформу, будь то сайт-сервис, интернет-магазин, личный кабинет пользователя и так далее. Так же сам функционал может быть изменен под ваши требования. Моя разработка не использует все доступные методы и возможности API(такой задачи не ставилось), например можно добавить функционал работы с адресной книгой и расширенные параметры заявок на оформление доставки груза.
Буду рад сотрудничеству, пишите!
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Интеграция с API ОСАГО сайта sravni.ru
- Комментарии на PHP, Ajax, mySQL
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Как создать Telegram-бота с авторизацией через сайт к записи
- PHP скрипт: каталог закладок на сайты к записи
- Валидация на PHP к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
Archive
- +2024 (29)
- Декабрь 2024 (1)
- Ноябрь 2024 (13)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Прокси веб-сервера Apache и nGinx 03.12.2024
- Настройка WebSocket на сайте для быстрого обмена данными 30.11.2024
- Подключение сайта к доставке DPD по API 28.11.2024
- Бот для автоматических заказов на Wildberries 22.11.2024
- Интеграция платежной системы MoonPay на сайт по API 10.11.2024