Интеграция сайта(ресторана) с API сервиса Quick Resto
Доброго времени друзья! Сегодня хочу поделиться опытом интеграции сайта ресторана с сервисом Quick Resto по API, для автоматизации всех бизнес-процессов, от склада до работы с клиентами. Система Quick Resto позволяет работать с: заказами, чеками, скидками, бонусами, клиентами, номенклатурой, складом, финансами, персоналом, терминалами, а также различными справочниками предустановленными в системе. Простой кейс интеграции сайта с API, это выгрузка на сайт актуального меню с ценами. Далее обо всем подробнее.
Общие сведения
API системы Quick Resto представляет собой сервер, клиенты которого передают на сервер запросы в формате JSON по протоколу HTTPS, используя методы GET и POST.
Базовый URL сервера: https://{layer_name}.quickresto.ru/platform/online/api/read
Тип авторизации: Базовая аутентификация — это простая схема аутентификации, встроенная в протокол HTTP. Клиент отправляет HTTP-запросы с заголовком Authorization, который содержит слово Basic, за которым следует пробел и строка в кодировке base64 username:password. Например, для авторизации как demo / p@55w0rd клиент должен отправить:
Authorization: Basic ZGVtbzpwQDU1dzByZA== |
Получение номенклатуры
Тип запроса: GET.
URL запроса: https://{layer_name}.quickresto.ru/platform/online/api/list?moduleName=warehouse.nomenclature.dish&className=ru.edgex.quickresto.modules.warehouse.nomenclature.dish.Dish
Пример запроса на PHP:
$host = 'https://{layer_name}.quickresto.ru/platform/online/api/list?moduleName=warehouse.nomenclature.dish&className=ru.edgex.quickresto.modules.warehouse.nomenclature.dish.Dish'; $ch = curl_init($host); curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json', 'Authorization: ' . base64_ecnode($username . ":" . $password))); curl_setopt($ch, CURLOPT_HEADER, 1); curl_setopt($ch, CURLOPT_TIMEOUT, 30); curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE); $return = curl_exec($ch); curl_close($ch); |
Ответ:
[
{
"displayOnTerminal": true,
"dishSales": [
{
"id": 0,
"salePlace": {
"title": "string",
"prechecksTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"reportTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"backupPrechecksTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"tableScheme": {
"id": 0,
"version": 0,
"name": "string",
"tables": [
{
"shape": "rect",
"title": "string",
"x": 0,
"y": 0,
"width": 0,
"height": 0,
"angle": 0,
"id": 0,
"version": 0,
"serverRegisterTime": "2019-08-24T14:15:22.456Z"
}
],
"webHalls": [
{
"deleted": true,
"tables": [
{}
],
"width": 0,
"height": 0,
"title": "string"
}
],
"width": 0,
"height": 0,
"itemTitle": "string",
"address": {
"fullAddress": "string",
"office": "string",
"floor": "string",
"doorcode": "string",
"entrance": "string",
"comment": "string",
"geocoding": {}
}
},
"openCashBoxOnPrechecks": true,
"openCashBoxOnReports": true,
"openCashBoxOnGuestTickets": true,
"maxTableOrderNumberEnable": true,
"maxTableOrderNumber": 0,
"defaultCookingPlace": {
"title": "string",
"store": {
"id": 0,
"title": "string",
"storeCode": "string",
"description": "string",
"liteBusiness": {
"name": "string",
"shortName": "string",
"address": "string",
"deliveryAddress": "string",
"innCode": "string",
"kppCode": "string",
"okpoCode": "string",
"bankId": "string",
"bankName": "string",
"account": "string",
"correspondentAccount": "string"
}
},
"targetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"backupTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"doublicatingTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"sendSignal": true,
"id": 0,
"version": 0,
"serverRegisterTime": "2019-08-24T14:15:22.456Z"
},
"id": 0,
"version": 0,
"serverRegisterTime": "2019-08-24T14:15:22.456Z"
},
"cookingPlace": {
"title": "string",
"store": {
"id": 0,
"title": "string",
"storeCode": "string",
"description": "string",
"liteBusiness": {
"name": "string",
"shortName": "string",
"address": "string",
"deliveryAddress": "string",
"innCode": "string",
"kppCode": "string",
"okpoCode": "string",
"bankId": "string",
"bankName": "string",
"account": "string",
"correspondentAccount": "string"
}
},
"targetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"backupTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"doublicatingTargetDevice": {
"id": 0,
"deviceId": "string",
"manufacturer": "string",
"model": "string",
"serialNumber": "string",
"connected": true,
"name": "string",
"deleted": true,
"code1C": "string",
"localIp": "string",
"macAddress": "string"
},
"sendSignal": true,
"id": 0,
"version": 0,
"serverRegisterTime": "2019-08-24T14:15:22.456Z"
}
}
],
"modifierLinks": [
{
"id": 0,
"version": 0,
"modifier": null,
"minValue": 0,
"maxValue": 0,
"defaultValue": 0,
"group": true
}
],
"excludeDeal": true,
"basePriceInList": 0,
"ratio": 0,
"vat": {
"id": 0,
"value": 0,
"taxType": "PRICE_INCLUDES_VAT"
},
"minimalPrice": 0,
"excludeDiscount": true,
"doNotAccumulateBonuses": true,
"doNotWithdrawBonuses": true,
"excludeMarkup": true,
"barCode": "string",
"code1C": "string",
"currentPrimeCost": 0,
"storeQuantityKg": 0,
"limit": 0,
"itemTitle": "string",
"parentId": 0,
"serverRegisterTime": "2019-08-24T14:15:22.456Z"
}
] |
Если вам требуется услуга интеграции вашего сайта с API Quick Resto, обращайтесь, буду рад вам помочь!
Похожие записи
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Комментарии на PHP, Ajax, mySQL
- Интеграция с API ОСАГО сайта sravni.ru
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- к записи Обзор Insurance CMS — платформы для сайтов по страхованию
- к записи Консольный скрипт(JavaScript) для автоматических заказов на OZON
- к записи Консольный скрипт(JavaScript) для автоматических заказов на OZON
- к записи Как создать Telegram-бота с авторизацией через сайт
- к записи PHP скрипт: каталог закладок на сайты
- к записи Валидация на PHP
- к записи Сколько зарабатывают в бизнесе на совместных покупках
Archive
- +2025 (28)
- Июль 2025 (1)
- Май 2025 (1)
- Апрель 2025 (7)
- Март 2025 (4)
- Февраль 2025 (9)
- Январь 2025 (6)
- +2024 (35)
- Декабрь 2024 (7)
- Ноябрь 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)
Свежие записи
- Список всех BIN российский банков в JSON 10.07.2025
- Плагин для WordPress, поддержка заголовка If-Modified-Since 22.05.2025
- Настройка NAT на OPNsense 30.04.2025
- Модуль для DLE парсинга RSS ленты с изображениями 14.04.2025
- Проверка CORS онлайн 04.04.2025